Skip to content

Conversation

@mkl-ableton
Copy link
Contributor

@mkl-ableton mkl-ableton commented Sep 12, 2025

This PR adds an overload of register_type that allows registering type aliases for val-based types. With this, clients can reference a stable, named type without needing to depend on (or update alongside) its underlying definition.

E.g.,

EMSCRIPTEN_DECLARE_VAL_TYPE(MyOwnEnum);

register_type<MyOwnEnum>("MyOwnEnum", "'a' | 'b'");

This addresses the issue raised in #25145.

@FelixNumworks
Copy link

Hi ! I opened a PR to do this in another way, by adding a parameter to enum_<MyEnum>

See #25257

The result in the d.ts file would be

export type MyEnum = 'valueOne'|'valueTwo'|'valueThree'

interface EmbindModule {
  MyEnum: {valueOne: 'valueOne', valueTwo: 'valueTwo', valueThree: 'valueThree'};
};

@FelixNumworks
Copy link

I know it's a bit different as my implementation only works for enums, and not any type, but I think it adresses the problem you raised in your discussion

@mkl-ableton
Copy link
Contributor Author

@FelixNumworks Thanks for pointing me to your PR. Exposing enums as strings is exactly my current use case. I hadn’t suggested modifying enum_ myself since I expected it might spark a bigger design discussion. Guess I should’ve just waited a week 🙂. Let’s see when/if your PR lands. I think this one makes sense regardless.

@mkl-ableton mkl-ableton force-pushed the add_overload_of_register_type branch from 6169ec6 to 19614c2 Compare September 12, 2025 17:32
@sbc100 sbc100 requested a review from brendandahl September 15, 2025 18:49
Copy link
Collaborator

@brendandahl brendandahl left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good. Can you push an update and i'll merge once tests run?

register_type<CallbackType>("(message: string) => void");
// Named alias form (emits: type Callback = (message: string) => void;)
// register_type<CallbackType>("Callback", "(message: string) => void");
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
// register_type<CallbackType>("Callback", "(message: string) => void");
register_type<CallbackType>("Callback", "(message: string) => void");

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I included that suggestion in 1deebdf

@mkl-ableton mkl-ableton force-pushed the add_overload_of_register_type branch from 19614c2 to c2469c3 Compare October 10, 2025 06:46
…lias

Introduce a second overload of register_type that creates a named TypeScript
alias for val-based types declared with EMSCRIPTEN_DECLARE_VAL_TYPE.

See changes in tests for examples.
@mkl-ableton mkl-ableton force-pushed the add_overload_of_register_type branch from c2469c3 to 1deebdf Compare October 10, 2025 07:53
@mkl-ableton
Copy link
Contributor Author

@brendandahl Thanks for the review. I rebased on main and AFAICT, tests pass now.

@mkl-ableton
Copy link
Contributor Author

@brendandahl I see that you approved the PR. Is there anything else I need to do to get it merged? AFAICT, I don't have permissions to merge it myself.

@brendandahl brendandahl enabled auto-merge (squash) October 15, 2025 15:26
@brendandahl brendandahl disabled auto-merge October 15, 2025 15:38
@brendandahl brendandahl merged commit 9ccceac into emscripten-core:main Oct 15, 2025
33 of 34 checks passed
@brendandahl
Copy link
Collaborator

Sorry about that, thought I'd enabled auto-merge earlier.

@mkl-ableton mkl-ableton deleted the add_overload_of_register_type branch October 16, 2025 07:04
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants